Serial No. 09/903,100 
Docket No. GSH 08-885923 
Amendment D 



AMENDMENTS TO THE CLAIMS : 

Kindly cancel claims 2-5, 7, 8, 14-16, 22 and 25-27, without prejudice, and amend 
claims 1, 6, 9, 13, 17, 21, 24, 28, 33 and 34, as set forth below. This listing of claims will 
replace all prior versions and listings of claim in the Application: 

Claim 1 (currently amended): A method for recovering an application from a runtime fault, 
the method comprising steps of: 

receiving an exception caused due to a runtime fault in a thread executing a C++ based 
application; 

dispatching the exception to an exception handler; 

trapping the exception before the exception reaches the exception handler when the 
exception handler is a top level exception handler which terminates the application; 

translating the trapped exception into a C++ exception that the C++ based application is 
capable of handlin g, wherein the trapped exception is translated into the C++ exception which 
is able to be resolved by an application defined C++ exception handler ; 

determining if there is an application based C++ exception handler which is capable of 
resolving the translated exception; 

terminating the thread that caused the exception when there is no C++ based exception 
handler which is capable of resolving the translated exception ; and 

continuing execution of the application. 
Claims 2-5 (canceled). 

Claim 6 (currently amended): The method recited in claim [[5]]1, wherein the continuing 
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step allows continuing execution of the application after the thread is terminated. 



Claims 7-8 (canceled). 
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Claim 9 (currently amended): The method recited in claim [[2]]i further comprising a step 
of logging state information representing the state that the application was in before occurrence 
of the exception caused the termination of the thread. 

Claim 10 (original): The method recited in claim 9 further comprising a step of forwarding 

the logged information to a remote database over a computer network. 

Claim 11 (original): The method recited in claim 10 further comprising steps of: 

receiving a recommendation from the remote database; and 

informing the recommendation to the user. 
Claim 12 (original): The method recited in claim 9 further comprising a step of forwarding a 
bug report to a bug report centre over a computer network. 

Claim 13 (currently amended): A method for recovering an application from a runtime fault 
in a thread, the application being executed under an operating system having one or more low 
level exception handlers and a top level exception handler, the method comprising steps of: 

trapping an exception [[which]] that is dispatched to the top level exception handler 
before the exception reaches the top level exception handler, the exception being caused due to 
a runtime fault in a thread executing a C++ based application, a default action of the top level 
exception handler being to terminate the application upon receipt of exceptions; 

translating the trapped exception into a C++ exception that the C++ based application is 
capable of handlin g, wherein the trapped exception is translated into the C++ exception which 
is able to be resolved by an application based C++ exception handler; 

the method further comprises a step of determining if there is an application based C++ 



terminating the thread that caused the exception when there is no C++ based exception 
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exception handler which is capable of resolving the translated exception: 
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continuing execution of the application. 
Claims 14-16 (canceled). 

Claim 17 (currently amended): The method recited in claim [[16]]J_3 further comprising a 
step of logging state information representing the state that the application was in before 
occurrence of the exception caused the termination of the thread. 

Claim 18 (original): The method recited in claim 17 further comprising a step of forwarding 

the logged information to a remote database over a computer network. 

Claim 19 (original): The method recited in claim 18 further comprising steps of: 

receiving a recommendation from the remote database; and 

informing the recommendation to the user. 
Claim 20 (original): The method recited in claim 17 further comprising a step of forwarding a 
bug report to a bug report centre over a computer network. 

Claim 21 (currently amended): An application recovery system for recovering an application 
from a runtime fault, the application recovery system comprising: 

an exception dispatcher for receiving an exception caused due to a runtime fault in a 
thread executing a C++ based application, and dispatching the exception to an exception 
handler; 

an exception trapper for trapping the exception before the exception causes termination 
of the application; 

an exception translator for translating the exception trapped by the exception trapper 
into a C++ exception that the C++ based application is capable of handling; 

a trapped exception handler for handling the trapped exception, the trapped exception 
handler having: 
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an exception handler selector for determining if there is an application based 
C++ exception handler that is capable of resolving the exception translated by the 
exception translator; and 

a thread terminator for terminating the thread when there is no C++ based 
exception handler that is capable of handling the translated exception: and 
an executor for continuing execution of the application. 
Claim 22 (canceled). 

Claim 23 (previously presented): The application recovery system as claimed in claim 21, 
wherein the exception trapper is provided in place of a top level exception handler which 
terminates the application. 

Claim 24 (currently amended): An application recovery system for recovering an application 
from a runtime fault caused in a thread, the application running under an operating system 
having an exception dispatcher, one or more low level exception handlers and a top level 
exception handler which terminates the application, the application recovery system 
comprising: 

an exception trapper placed between the exception dispatcher and the top level 
exception handler for trapping an exception before the exception reaches the top level 
exception handler, the exception being caused due to a runtime fault in a thread executing a 
C++ based application; 

an exception translator for translating the trapped exception into a C++ exception that 
the C++ based application is capable of handling; and 

a trapped exception handler for handling the trapped exception , the trapped exception 
handler having: 
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an exception handler selector for determining if there is an application based 
C++ exception handler that is capable of resolving the exception translated by the 
exception translator; and 

a thread terminator for terminating the thread when there is no C++ based 
exception handler that is capable of handling the translated exception . 
Claims 25-27 (canceled). 

Claim 28 (currently amended): The application recovery system recited in claim [[27]]24, 
wherein the trapped exception handler further comprises a state restorer for restoring the state 
that the application was in before the fault occurred to continue the execution of the 
application. 

Claim 29 (original): The application recovery system recited in claim 24 further comprising a 
state information logger for logging information of the state that the application was in before 
the fault occurred. 

Claim 30 (original): The application recovery system recited in claim 29 further comprising a 
query generator for generating a query including the state information to query a 
recommendation from a remote database over a computer network. 
Claim 31 (original): The application recovery system as claimed in claim 30 further 
comprising a user advisor for receiving a recommendation from the remote database and 
informing the user of the recommendation. 

Claim 32 (original): The application recovery system as claimed in claim 30 wherein the 
query generator has a bug report generator for forwarding a bug report with the state 
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Claim 33 (currently amended): A computer readable memory element storing the 
instructions or statements for use in the execution in a computer of a method for recovering an 
application from a runtime fault, the method comprising steps of: 

receiving an exception caused due to a runtime fault in a thread executing a C++ based 
application; 

dispatching the exception to an exception handler; 

trapping the exception before the exception reaches the exception handler when the 
exception handler is a top level exception handler which terminates the application; 

translating the trapped exception into [[an]] a C++ exception that the C++ application is 
capable of handling , wherein the trapped exception is translated into the C++ exception which 
is able to be resolved by an application defined C++ exception handler ; 

determining if there is an application based C++ exception handler which is capable of 
resolving the translated exception; 

terminating the thread that caused the exception when there is no C++ based exception 
handler which is capable of resolving the translated exception ; and 

continuing execution of the application. 
Claim 34 (currently amended): Electronic signals for use in the execution in a computer of a 
method for recovering an application from a runtime fault, the method comprising steps of: 

receiving an exception caused due to a runtime fault in a thread executing a C++ based 
application; 

dispatching the exception to an exception handler; 

trapping the exception before the exception reaches the exception handler when the 
exception handler is a top level exception handler which terminates the application; 
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translating the trapped exception into a C++ exception that the C++ based application is 
capable of handling , wherein the trapped exception is translated into the C++ exception which 
is able to be resolved by an application defined C++ exception handler ; 

determining if there is an application based C++ exception handler which is capable of 
resolving the translated exception; 

terminating the thread that caused the exception when there is no C++ based exception 
handler which is capable of resolving the translated exception ; and 
continuing execution of the application. 
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